<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>webdoc</title>
    <link rel="stylesheet" type="text/css" href="../static/css/main.css">
</head>
<body>
<div class="nav">
    <div class="logo">
        
            webdoc
        
    </div>
<ul><li><a href="../index.html">0.Async</a></li><li><a href="../html/0.editor.html">0.editor</a></li><li><a href="../html/0.module.html">0.module</a></li><li><a href="../html/1.ES2015.html">1.ES2015</a></li><li><a href="../html/2.Promise.html">2.Promise</a></li><li class="active"><a href="../html/3.Node.html">3.Node</a></li><li><a href="../html/4.NodeInstall.html">4.NodeInstall</a></li><li><a href="../html/5.REPL.html">5.REPL</a></li><li><a href="../html/6.NodeCore.html">6.NodeCore</a></li><li><a href="../html/7.module&NPM.html">7.module&NPM</a></li><li><a href="../html/8.Encoding.html">8.Encoding</a></li><li><a href="../html/9.Buffer.html">9.Buffer</a></li><li><a href="../html/10.fs.html">10.fs</a></li><li><a href="../html/11.Stream-1.html">11.Stream-1</a></li><li><a href="../html/11.Stream-2.html">11.Stream-2</a></li><li><a href="../html/11.Stream-3.html">11.Stream-3</a></li><li><a href="../html/11.Stream-4.html">11.Stream-4</a></li><li><a href="../html/12-Network-2.html">12-Network-2</a></li><li><a href="../html/12.NetWork-3.html">12.NetWork-3</a></li><li><a href="../html/12.Network-1.html">12.Network-1</a></li><li><a href="../html/13.tcp.html">13.tcp</a></li><li><a href="../html/14.http-1.html">14.http-1</a></li><li><a href="../html/14.http-2.html">14.http-2</a></li><li><a href="../html/15.compress.html">15.compress</a></li><li><a href="../html/16.crypto.html">16.crypto</a></li><li><a href="../html/17.process.html">17.process</a></li><li><a href="../html/18.yargs.html">18.yargs</a></li><li><a href="../html/19.cache.html">19.cache</a></li><li><a href="../html/20.action.html">20.action</a></li><li><a href="../html/21.https.html">21.https</a></li><li><a href="../html/22.cookie.html">22.cookie</a></li><li><a href="../html/23.session.html">23.session</a></li><li><a href="../html/24.express-1.html">24.express-1</a></li><li><a href="../html/24.express-2.html">24.express-2</a></li><li><a href="../html/24.express-3.html">24.express-3</a></li><li><a href="../html/24.express-4.html">24.express-4</a></li><li><a href="../html/25.koa-1.html">25.koa-1</a></li><li><a href="../html/26.webpack-1-basic.html">26.webpack-1-basic</a></li><li><a href="../html/26.webpack-2-optimize.html">26.webpack-2-optimize</a></li><li><a href="../html/26.webpack-3.tapable.html">26.webpack-3.tapable</a></li><li><a href="../html/26.webpack-4-AST.html">26.webpack-4-AST</a></li><li><a href="../html/26.webpack-5-source.html">26.webpack-5-source</a></li><li><a href="../html/26.webpack-6-loader.html">26.webpack-6-loader</a></li><li><a href="../html/26.webpack-7-plugin.html">26.webpack-7-plugin</a></li><li><a href="../html/26.webpack-8-hand.html">26.webpack-8-hand</a></li><li><a href="../html/27.react-1.html">27.react-1</a></li><li><a href="../html/27.react-2.html">27.react-2</a></li><li><a href="../html/27.react-3.html">27.react-3</a></li><li><a href="../html/27.react-4-immutable.html">27.react-4-immutable</a></li><li><a href="../html/27.react-5-react-dom-diff.html">27.react-5-react-dom-diff</a></li><li><a href="../html/27.react-6.html">27.react-6</a></li><li><a href="../html/28.react-mobx.html">28.react-mobx</a></li><li><a href="../html/28.redux-0.html">28.redux-0</a></li><li><a href="../html/28.redux-1.html">28.redux-1</a></li><li><a href="../html/28.redux-2-中间件.html">28.redux-2-中间件</a></li><li><a href="../html/28.redux-3-saga.html">28.redux-3-saga</a></li><li><a href="../html/28.redux-jwt-back.html">28.redux-jwt-back</a></li><li><a href="../html/28.redux-jwt-front.html">28.redux-jwt-front</a></li><li><a href="../html/29.mongodb-1.html">29.mongodb-1</a></li><li><a href="../html/29.mongodb-2.html">29.mongodb-2</a></li><li><a href="../html/29.mongodb-3.html">29.mongodb-3</a></li><li><a href="../html/29.mongodb-4.html">29.mongodb-4</a></li><li><a href="../html/29.mongodb-5.html">29.mongodb-5</a></li><li><a href="../html/29.mongodb-6.html">29.mongodb-6</a></li><li><a href="../html/30.cms-1-mysql.html">30.cms-1-mysql</a></li><li><a href="../html/30.cms-2-mysql.html">30.cms-2-mysql</a></li><li><a href="../html/30.cms-3-mysql.html">30.cms-3-mysql</a></li><li><a href="../html/30.cms-4-egg.html">30.cms-4-egg</a></li><li><a href="../html/30.cms-5-api.html">30.cms-5-api</a></li><li><a href="../html/30.cms-6-roadhog.html">30.cms-6-roadhog</a></li><li><a href="../html/30.cms-7-umi.html">30.cms-7-umi</a></li><li><a href="../html/30.cms-8-dva.html">30.cms-8-dva</a></li><li><a href="../html/30.cms-9-dva.html">30.cms-9-dva</a></li><li><a href="../html/30.cms-10-dva.html">30.cms-10-dva</a></li><li><a href="../html/30.cms-11-front.html">30.cms-11-front</a></li><li><a href="../html/31.cms-12-api.html">31.cms-12-api</a></li><li><a href="../html/31.cms-13-front.html">31.cms-13-front</a></li><li><a href="../html/31.cms-14-deploy.html">31.cms-14-deploy</a></li><li><a href="../html/32.ant.html">32.ant</a></li><li><a href="../html/33.redis.html">33.redis</a></li><li><a href="../html/34.unittest.html">34.unittest</a></li><li><a href="../html/35.jwt.html">35.jwt</a></li><li><a href="../html/36.websocket-1.html">36.websocket-1</a></li><li><a href="../html/36.websocket-2.html">36.websocket-2</a></li><li><a href="../html/38.chat-api-1.html">38.chat-api-1</a></li><li><a href="../html/38.chat-api-2.html">38.chat-api-2</a></li><li><a href="../html/38.chat-3.html">38.chat-3</a></li><li><a href="../html/38.chat-api-3.html">38.chat-api-3</a></li><li><a href="../html/38.chat.html">38.chat</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/39.crawl-0.html">39.crawl-0</a></li><li><a href="../html/39.crawl-1.html">39.crawl-1</a></li><li><a href="../html/39.crawl-2.html">39.crawl-2</a></li><li><a href="../html/40.deploy.html">40.deploy</a></li><li><a href="../html/41.safe.html">41.safe</a></li><li><a href="../html/42.test.html">42.test</a></li><li><a href="../html/43.nginx.html">43.nginx</a></li><li><a href="../html/44.enzyme.html">44.enzyme</a></li><li><a href="../html/45.docker.html">45.docker</a></li><li><a href="../html/46.elastic.html">46.elastic</a></li><li><a href="../html/47.oauth.html">47.oauth</a></li><li><a href="../html/48.wxpay.html">48.wxpay</a></li><li><a href="../html/49.nunjucks.html">49.nunjucks</a></li><li><a href="../html/50.ketang.html">50.ketang</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/51.typescript.html">51.typescript</a></li><li><a href="../html/52.UML.html">52.UML</a></li><li><a href="../html/53.design.html">53.design</a></li><li><a href="../html/index.html">index</a></li></ul></div>


<div class="warpper">

    <div class="page-toc">
        <ul><li><a href="#t01. Node能够解决什么问题?">1. Node能够解决什么问题?</a></li><li><a href="#t12. Node是什么?">2. Node是什么?</a></li><li><a href="#t23. Node特点">3. Node特点</a><ul><li><a href="#t33.1 为什么JavaScript是单线程？">3.1 为什么JavaScript是单线程？</a></li><li><a href="#t43.2 浏览器模型">3.2 浏览器模型</a></li><li><a href="#t53.3 除JS线程和UI线程之外的其它线程">3.3 除JS线程和UI线程之外的其它线程</a></li><li><a href="#t63.4 任务队列">3.4 任务队列</a></li><li><a href="#t73.5. Event Loop">3.5. Event Loop</a></li><li><a href="#t83.6. Node.js的Event Loop">3.6. Node.js的Event Loop</a></li><li><a href="#t93.7. 同步与异步">3.7. 同步与异步</a></li><li><a href="#t103.8. 阻塞与非阻塞">3.8. 阻塞与非阻塞</a></li><li><a href="#t113.9. 组合">3.9. 组合</a></li></ul></li><li><a href="#t124.什么场合下应该考虑使用Node框架">4.什么场合下应该考虑使用Node框架</a></li></ul>
    </div>
    
    <div class="content markdown-body">
        <h2 id="t01. Node&#x80FD;&#x591F;&#x89E3;&#x51B3;&#x4EC0;&#x4E48;&#x95EE;&#x9898;?">1. Node&#x80FD;&#x591F;&#x89E3;&#x51B3;&#x4EC0;&#x4E48;&#x95EE;&#x9898;? <a href="#t01. Node&#x80FD;&#x591F;&#x89E3;&#x51B3;&#x4EC0;&#x4E48;&#x95EE;&#x9898;?"> # </a></h2>
<ul>
<li>Node&#x7684;&#x9996;&#x8981;&#x76EE;&#x6807;&#x662F;&#x63D0;&#x4F9B;&#x4E00;&#x79CD;&#x7B80;&#x5355;&#x7684;&#xFF0C;&#x7528;&#x4E8E;&#x521B;&#x5EFA;&#x9AD8;&#x6027;&#x80FD;&#x670D;&#x52A1;&#x5668;&#x7684;&#x5F00;&#x53D1;&#x5DE5;&#x5177;</li>
<li>Web&#x670D;&#x52A1;&#x5668;&#x7684;&#x74F6;&#x9888;&#x5728;&#x4E8E;&#x5E76;&#x53D1;&#x7684;&#x7528;&#x6237;&#x91CF;&#xFF0C;&#x5BF9;&#x6BD4;Java&#x548C;Php&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;</li>
</ul>
<h2 id="t12. Node&#x662F;&#x4EC0;&#x4E48;?">2. Node&#x662F;&#x4EC0;&#x4E48;? <a href="#t12. Node&#x662F;&#x4EC0;&#x4E48;?"> # </a></h2>
<ul>
<li>Node.js &#x662F;&#x4E00;&#x4E2A;&#x57FA;&#x4E8E; Chrome V8 &#x5F15;&#x64CE;&#x7684; JavaScript &#x8FD0;&#x884C;&#x73AF;&#x5883;,&#x8BA9;JavaScript&#x7684;&#x6267;&#x884C;&#x6548;&#x7387;&#x4E0E;&#x4F4E;&#x7AEF;&#x7684;C&#x8BED;&#x8A00;&#x7684;&#x76F8;&#x8FD1;&#x7684;&#x6267;&#x884C;&#x6548;&#x7387;&#x3002;&#x3002;</li>
<li>Node.js &#x4F7F;&#x7528;&#x4E86;&#x4E00;&#x4E2A;&#x4E8B;&#x4EF6;&#x9A71;&#x52A8;&#x3001;&#x975E;&#x963B;&#x585E;&#x5F0F; I/O &#x7684;&#x6A21;&#x578B;&#xFF0C;&#x4F7F;&#x5176;&#x8F7B;&#x91CF;&#x53C8;&#x9AD8;&#x6548;&#x3002;</li>
<li>Node.js &#x7684;&#x5305;&#x7BA1;&#x7406;&#x5668; npm&#xFF0C;&#x662F;&#x5168;&#x7403;&#x6700;&#x5927;&#x7684;&#x5F00;&#x6E90;&#x5E93;&#x751F;&#x6001;&#x7CFB;&#x7EDF;&#x3002;</li>
</ul>
<h2 id="t23. Node&#x7279;&#x70B9;">3. Node&#x7279;&#x70B9; <a href="#t23. Node&#x7279;&#x70B9;"> # </a></h2>
<h3 id="t33.1 &#x4E3A;&#x4EC0;&#x4E48;JavaScript&#x662F;&#x5355;&#x7EBF;&#x7A0B;&#xFF1F;">3.1 &#x4E3A;&#x4EC0;&#x4E48;JavaScript&#x662F;&#x5355;&#x7EBF;&#x7A0B;&#xFF1F; <a href="#t33.1 &#x4E3A;&#x4EC0;&#x4E48;JavaScript&#x662F;&#x5355;&#x7EBF;&#x7A0B;&#xFF1F;"> # </a></h3>
<ul>
<li>&#x8FD9;&#x662F;&#x7531; Javascript &#x8FD9;&#x95E8;&#x811A;&#x672C;&#x8BED;&#x8A00;&#x7684;&#x7528;&#x9014;&#x51B3;&#x5B9A;&#x7684;&#x3002;</li>
<li>Web Worker&#x5E76;&#x6CA1;&#x6709;&#x6539;&#x53D8; JavaScript &#x5355;&#x7EBF;&#x7A0B;&#x7684;&#x672C;&#x8D28;&#x3002;</li>
</ul>
<h3 id="t43.2 &#x6D4F;&#x89C8;&#x5668;&#x6A21;&#x578B;">3.2 &#x6D4F;&#x89C8;&#x5668;&#x6A21;&#x578B; <a href="#t43.2 &#x6D4F;&#x89C8;&#x5668;&#x6A21;&#x578B;"> # </a></h3>
<ul>
<li>&#x7528;&#x6237;&#x754C;&#x9762;-&#x5305;&#x62EC;&#x5730;&#x5740;&#x680F;&#x3001;&#x524D;&#x8FDB;/&#x540E;&#x9000;&#x6309;&#x94AE;&#x3001;&#x4E66;&#x7B7E;&#x83DC;&#x5355;&#x7B49;</li>
<li>&#x6D4F;&#x89C8;&#x5668;&#x5F15;&#x64CE;-&#x5728;&#x7528;&#x6237;&#x754C;&#x9762;&#x548C;&#x5448;&#x73B0;&#x5F15;&#x64CE;&#x4E4B;&#x95F4;&#x4F20;&#x9001;&#x6307;&#x4EE4;</li>
<li>&#x5448;&#x73B0;&#x5F15;&#x64CE;-&#x53C8;&#x79F0;&#x6E32;&#x67D3;&#x5F15;&#x64CE;&#xFF0C;&#x4E5F;&#x88AB;&#x79F0;&#x4E3A;&#x6D4F;&#x89C8;&#x5668;&#x5185;&#x6838;&#xFF0C;&#x5728;&#x7EBF;&#x7A0B;&#x65B9;&#x9762;&#x53C8;&#x79F0;&#x4E3A;UI&#x7EBF;&#x7A0B;</li>
<li>&#x7F51;&#x7EDC;-&#x7528;&#x4E8E;&#x7F51;&#x7EDC;&#x8C03;&#x7528;&#xFF0C;&#x6BD4;&#x5982; HTTP &#x8BF7;&#x6C42;</li>
<li>&#x7528;&#x6237;&#x754C;&#x9762;&#x540E;&#x7AEF;-&#x7528;&#x4E8E;&#x7ED8;&#x5236;&#x57FA;&#x672C;&#x7684;&#x7A97;&#x53E3;&#x5C0F;&#x90E8;&#x4EF6;,UI&#x7EBF;&#x7A0B;&#x548C;JS&#x5171;&#x7528;&#x4E00;&#x4E2A;&#x7EBF;&#x7A0B;</li>
<li>JavaScript&#x89E3;&#x91CA;&#x5668;-&#x7528;&#x4E8E;&#x89E3;&#x6790;&#x548C;&#x6267;&#x884C; JavaScript &#x4EE3;&#x7801;</li>
<li>&#x6570;&#x636E;&#x5B58;&#x50A8;-&#x8FD9;&#x662F;&#x6301;&#x4E45;&#x5C42;&#x3002;&#x6D4F;&#x89C8;&#x5668;&#x9700;&#x8981;&#x5728;&#x786C;&#x76D8;&#x4E0A;&#x4FDD;&#x5B58;&#x5404;&#x79CD;&#x6570;&#x636E;&#xFF0C;&#x4F8B;&#x5982; Cookie</li>
</ul>
<p><img src="http://img.zhufengpeixun.cn/browser.jpg" alt="&#x6D4F;&#x89C8;&#x5668;"></p>
<h3 id="t53.3 &#x9664;JS&#x7EBF;&#x7A0B;&#x548C;UI&#x7EBF;&#x7A0B;&#x4E4B;&#x5916;&#x7684;&#x5176;&#x5B83;&#x7EBF;&#x7A0B;">3.3 &#x9664;JS&#x7EBF;&#x7A0B;&#x548C;UI&#x7EBF;&#x7A0B;&#x4E4B;&#x5916;&#x7684;&#x5176;&#x5B83;&#x7EBF;&#x7A0B; <a href="#t53.3 &#x9664;JS&#x7EBF;&#x7A0B;&#x548C;UI&#x7EBF;&#x7A0B;&#x4E4B;&#x5916;&#x7684;&#x5176;&#x5B83;&#x7EBF;&#x7A0B;"> # </a></h3>
<ul>
<li>&#x6D4F;&#x89C8;&#x5668;&#x4E8B;&#x4EF6;&#x89E6;&#x53D1;&#x7EBF;&#x7A0B;</li>
<li>&#x5B9A;&#x65F6;&#x89E6;&#x53D1;&#x5668;&#x7EBF;&#x7A0B;</li>
<li>&#x5F02;&#x6B65;HTTP&#x8BF7;&#x6C42;&#x7EBF;&#x7A0B;</li>
</ul>
<h3 id="t63.4 &#x4EFB;&#x52A1;&#x961F;&#x5217;">3.4 &#x4EFB;&#x52A1;&#x961F;&#x5217; <a href="#t63.4 &#x4EFB;&#x52A1;&#x961F;&#x5217;"> # </a></h3>
<ol>
<li>&#x6240;&#x6709;&#x540C;&#x6B65;&#x4EFB;&#x52A1;&#x90FD;&#x5728;&#x4E3B;&#x7EBF;&#x7A0B;&#x4E0A;&#x6267;&#x884C;&#xFF0C;&#x5F62;&#x6210;&#x4E00;&#x4E2A;&#x6267;&#x884C;&#x6808;</li>
<li>&#x4E3B;&#x7EBF;&#x7A0B;&#x4E4B;&#x5916;&#xFF0C;&#x8FD8;&#x5B58;&#x5728;&#x4E00;&#x4E2A;&#x4EFB;&#x52A1;&#x961F;&#x5217;&#x3002;&#x53EA;&#x8981;&#x5F02;&#x6B65;&#x4EFB;&#x52A1;&#x6709;&#x4E86;&#x8FD0;&#x884C;&#x7ED3;&#x679C;&#xFF0C;&#x5C31;&#x5728;&#x4EFB;&#x52A1;&#x961F;&#x5217;&#x4E4B;&#x4E2D;&#x653E;&#x7F6E;&#x4E00;&#x4E2A;&#x4E8B;&#x4EF6;&#x3002;</li>
<li>&#x4E00;&#x65E6;&#x6267;&#x884C;&#x6808;&#x4E2D;&#x7684;&#x6240;&#x6709;<strong>&#x540C;&#x6B65;&#x4EFB;&#x52A1;</strong>&#x6267;&#x884C;&#x5B8C;&#x6BD5;&#xFF0C;&#x7CFB;&#x7EDF;&#x5C31;&#x4F1A;&#x8BFB;&#x53D6;<strong>&#x4EFB;&#x52A1;&#x961F;&#x5217;</strong>&#xFF0C;&#x770B;&#x770B;&#x91CC;&#x9762;&#x6709;&#x54EA;&#x4E9B;&#x4E8B;&#x4EF6;&#x3002;&#x90A3;&#x4E9B;&#x5BF9;&#x5E94;&#x7684;&#x5F02;&#x6B65;&#x4EFB;&#x52A1;&#xFF0C;&#x4E8E;&#x662F;&#x7ED3;&#x675F;&#x7B49;&#x5F85;&#x72B6;&#x6001;&#xFF0C;&#x8FDB;&#x5165;&#x6267;&#x884C;&#x6808;&#xFF0C;&#x5F00;&#x59CB;&#x6267;&#x884C;&#x3002;</li>
<li>&#x4E3B;&#x7EBF;&#x7A0B;&#x4E0D;&#x65AD;&#x91CD;&#x590D;&#x4E0A;&#x9762;&#x7684;&#x7B2C;&#x4E09;&#x6B65;&#x3002;</li>
</ol>
<h3 id="t73.5. Event Loop">3.5. Event Loop <a href="#t73.5. Event Loop"> # </a></h3>
<p>&#x4E3B;&#x7EBF;&#x7A0B;&#x4ECE;<strong>&#x4EFB;&#x52A1;&#x961F;&#x5217;</strong>&#x4E2D;&#x8BFB;&#x53D6;&#x4E8B;&#x4EF6;&#xFF0C;&#x8FD9;&#x4E2A;&#x8FC7;&#x7A0B;&#x662F;&#x5FAA;&#x73AF;&#x4E0D;&#x65AD;&#x7684;&#xFF0C;&#x6240;&#x4EE5;&#x6574;&#x4E2A;&#x7684;&#x8FD9;&#x79CD;&#x8FD0;&#x884C;&#x673A;&#x5236;&#x53C8;&#x79F0;&#x4E3A;Event Loop(&#x4E8B;&#x4EF6;&#x5FAA;&#x73AF;)</p>
<p><img src="http://img.zhufengpeixun.cn/eventloop.png" alt="eventloop"></p>
<h3 id="t83.6. Node.js&#x7684;Event Loop">3.6. Node.js&#x7684;Event Loop <a href="#t83.6. Node.js&#x7684;Event Loop"> # </a></h3>
<p><img src="http://img.zhufengpeixun.cn/nodesystem.png" alt="eventloop"></p>
<ol>
<li>V8&#x5F15;&#x64CE;&#x89E3;&#x6790;JavaScript&#x811A;&#x672C;&#x3002;</li>
<li>&#x89E3;&#x6790;&#x540E;&#x7684;&#x4EE3;&#x7801;&#xFF0C;&#x8C03;&#x7528;Node API&#x3002;</li>
<li>libuv&#x5E93;&#x8D1F;&#x8D23;Node API&#x7684;&#x6267;&#x884C;&#x3002;&#x5B83;&#x5C06;&#x4E0D;&#x540C;&#x7684;&#x4EFB;&#x52A1;&#x5206;&#x914D;&#x7ED9;&#x4E0D;&#x540C;&#x7684;&#x7EBF;&#x7A0B;&#xFF0C;&#x5F62;&#x6210;&#x4E00;&#x4E2A;Event Loop&#xFF08;&#x4E8B;&#x4EF6;&#x5FAA;&#x73AF;&#xFF09;&#xFF0C;&#x4EE5;&#x5F02;&#x6B65;&#x7684;&#x65B9;&#x5F0F;&#x5C06;&#x4EFB;&#x52A1;&#x7684;&#x6267;&#x884C;&#x7ED3;&#x679C;&#x8FD4;&#x56DE;&#x7ED9;V8&#x5F15;&#x64CE;&#x3002;</li>
<li>V8&#x5F15;&#x64CE;&#x518D;&#x5C06;&#x7ED3;&#x679C;&#x8FD4;&#x56DE;&#x7ED9;&#x7528;&#x6237;&#x3002;</li>
</ol>
<h3 id="t93.7. &#x540C;&#x6B65;&#x4E0E;&#x5F02;&#x6B65;">3.7. &#x540C;&#x6B65;&#x4E0E;&#x5F02;&#x6B65; <a href="#t93.7. &#x540C;&#x6B65;&#x4E0E;&#x5F02;&#x6B65;"> # </a></h3>
<p>&#x540C;&#x6B65;&#x548C;&#x5F02;&#x6B65;&#x5173;&#x6CE8;&#x7684;&#x662F;&#x6D88;&#x606F;&#x901A;&#x77E5;&#x673A;&#x5236;</p>
<ul>
<li><p>&#x540C;&#x6B65;&#x5C31;&#x662F;&#x53D1;&#x51FA;&#x8C03;&#x7528;&#x540E;&#xFF0C;&#x6CA1;&#x6709;&#x5F97;&#x5230;&#x7ED3;&#x679C;&#x4E4B;&#x524D;&#xFF0C;&#x8BE5;&#x8C03;&#x7528;&#x4E0D;&#x8FD4;&#x56DE;&#xFF0C;&#x4E00;&#x65E6;&#x8C03;&#x7528;&#x8FD4;&#x56DE;&#xFF0C;&#x5C31;&#x5F97;&#x5230;&#x8FD4;&#x56DE;&#x503C;&#x4E86;&#x3002;
&#x7B80;&#x800C;&#x8A00;&#x4E4B;&#x5C31;&#x662F;&#x8C03;&#x7528;&#x8005;&#x4E3B;&#x52A8;&#x7B49;&#x5F85;&#x8FD9;&#x4E2A;&#x8C03;&#x7528;&#x7684;&#x7ED3;&#x679C;</p>
</li>
<li><p>&#x800C;&#x5F02;&#x6B65;&#x5219;&#x76F8;&#x53CD;&#xFF0C;&#x8C03;&#x7528;&#x8005;&#x5728;&#x53D1;&#x51FA;&#x8C03;&#x7528;&#x540E;&#x8FD9;&#x4E2A;&#x8C03;&#x7528;&#x5C31;&#x76F4;&#x63A5;&#x8FD4;&#x56DE;&#x4E86;&#xFF0C;&#x6240;&#x4EE5;&#x6CA1;&#x6709;&#x8FD4;&#x56DE;&#x7ED3;&#x679C;&#x3002;&#x6362;&#x53E5;&#x8BDD;&#x8BF4;&#x5F53;&#x4E00;&#x4E2A;&#x5F02;&#x6B65;&#x8FC7;&#x7A0B;&#x8C03;&#x7528;&#x53D1;&#x51FA;&#x540E;&#xFF0C;&#x8C03;&#x7528;&#x8005;&#x4E0D;&#x4F1A;&#x7ACB;&#x523B;&#x5F97;&#x5230;&#x7ED3;&#x679C;&#xFF0C;&#x800C;&#x662F;&#x8C03;&#x7528;&#x53D1;&#x51FA;&#x540E;&#xFF0C;&#x88AB;&#x8C03;&#x7528;&#x8005;&#x901A;&#x8FC7;&#x72B6;&#x6001;&#x3001;&#x901A;&#x77E5;&#x6216;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x5904;&#x7406;&#x8FD9;&#x4E2A;&#x8C03;&#x7528;&#x3002;</p>
</li>
</ul>
<h3 id="t103.8. &#x963B;&#x585E;&#x4E0E;&#x975E;&#x963B;&#x585E;">3.8. &#x963B;&#x585E;&#x4E0E;&#x975E;&#x963B;&#x585E; <a href="#t103.8. &#x963B;&#x585E;&#x4E0E;&#x975E;&#x963B;&#x585E;"> # </a></h3>
<p>&#x963B;&#x585E;&#x548C;&#x975E;&#x963B;&#x585E;&#x5173;&#x6CE8;&#x7684;&#x662F;&#x7A0B;&#x5E8F;&#x5728;&#x7B49;&#x5F85;&#x8C03;&#x7528;&#x7ED3;&#x679C;&#xFF08;&#x6D88;&#x606F;&#xFF0C;&#x8FD4;&#x56DE;&#x503C;&#xFF09;&#x65F6;&#x7684;&#x72B6;&#x6001;.</p>
<ul>
<li>&#x963B;&#x585E;&#x8C03;&#x7528;&#x662F;&#x6307;&#x8C03;&#x7528;&#x7ED3;&#x679C;&#x8FD4;&#x56DE;&#x4E4B;&#x524D;&#xFF0C;&#x5F53;&#x524D;&#x7EBF;&#x7A0B;&#x4F1A;&#x88AB;&#x6302;&#x8D77;&#x3002;&#x8C03;&#x7528;&#x7EBF;&#x7A0B;&#x53EA;&#x6709;&#x5728;&#x5F97;&#x5230;&#x7ED3;&#x679C;&#x4E4B;&#x540E;&#x624D;&#x4F1A;&#x8FD4;&#x56DE;&#x3002;</li>
<li>&#x975E;&#x963B;&#x585E;&#x8C03;&#x7528;&#x6307;&#x5728;&#x4E0D;&#x80FD;&#x7ACB;&#x523B;&#x5F97;&#x5230;&#x7ED3;&#x679C;&#x4E4B;&#x524D;&#xFF0C;&#x8BE5;&#x8C03;&#x7528;&#x4E0D;&#x4F1A;&#x963B;&#x585E;&#x5F53;&#x524D;&#x7EBF;&#x7A0B;&#x3002;</li>
</ul>
<h3 id="t113.9. &#x7EC4;&#x5408;">3.9. &#x7EC4;&#x5408; <a href="#t113.9. &#x7EC4;&#x5408;"> # </a></h3>
<p>&#x540C;&#x6B65;&#x5F02;&#x6B65;&#x53D6;&#x51B3;&#x4E8E;&#x88AB;&#x8C03;&#x7528;&#x8005;&#xFF0C;&#x963B;&#x585E;&#x975E;&#x963B;&#x585E;&#x53D6;&#x51B3;&#x4E8E;&#x8C03;&#x7528;&#x8005;</p>
<ul>
<li>&#x540C;&#x6B65;&#x963B;&#x585E;</li>
<li>&#x5F02;&#x6B65;&#x963B;&#x585E;</li>
<li>&#x540C;&#x6B65;&#x975E;&#x963B;&#x585E;</li>
<li>&#x5F02;&#x6B65;&#x975E;&#x963B;&#x585E;</li>
</ul>
<h2 id="t124.&#x4EC0;&#x4E48;&#x573A;&#x5408;&#x4E0B;&#x5E94;&#x8BE5;&#x8003;&#x8651;&#x4F7F;&#x7528;Node&#x6846;&#x67B6;">4.&#x4EC0;&#x4E48;&#x573A;&#x5408;&#x4E0B;&#x5E94;&#x8BE5;&#x8003;&#x8651;&#x4F7F;&#x7528;Node&#x6846;&#x67B6; <a href="#t124.&#x4EC0;&#x4E48;&#x573A;&#x5408;&#x4E0B;&#x5E94;&#x8BE5;&#x8003;&#x8651;&#x4F7F;&#x7528;Node&#x6846;&#x67B6;"> # </a></h2>
<p>&#x5F53;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x9700;&#x8981;&#x5904;&#x7406;&#x5927;&#x91CF;&#x5E76;&#x53D1;&#x7684;&#x8F93;&#x5165;&#x8F93;&#x51FA;&#xFF0C;&#x800C;&#x5728;&#x5411;&#x5BA2;&#x6237;&#x7AEF;&#x54CD;&#x5E94;&#x4E4B;&#x524D;&#xFF0C;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x5E76;&#x4E0D;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x975E;&#x5E38;&#x590D;&#x6742;&#x7684;&#x5904;&#x7406;&#x3002;</p>
<ul>
<li>&#x804A;&#x5929;&#x670D;&#x52A1;&#x5668;</li>
<li>&#x7535;&#x5B50;&#x5546;&#x52A1;&#x7F51;&#x7AD9;</li>
</ul>

        <div class="copyright">Powered by <a href="https://github.com/jaywcjlove/idoc" target="_blank">idoc</a>. Dependence <a href="https://nodejs.org">Node.js</a> run.</div>
    </div>
    
</div>

<script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.js"></script>
<script>
$('.warpper .page-toc ul ul li a').on('click',function(){
  $('.warpper .page-toc ul ul li a').removeClass('my-active')
  $(this).addClass('my-active')
})
  // if (!$('.understand-me').length) {
  //   var bar = $(window).height() - $('.navbar ').height() - $('.page-toc').position().top;
  //   var count = bar / 26 / 2;
  //   var barHeight = $('.page-toc').outerHeight();
  //   $('.page-toc li').eq(0).children('a').addClass('red');
  //   var arr = [];
  //   $("h1,h2,h3,h4,h5,h6").each(function () {
  //     arr.push($(this).position().top);
  //   });
  //   var timer
  //   function dark() {
  //     clearTimeout(timer)
  //      timer = setTimeout(function () {
  //      var top = Math.abs($('.page-toc > ul').position().top);
  //      var cur = $('.content').scrollTop();
  //      for (var i = arr.length; i >= 0; i--) {
  //        if (arr[i] <= cur) {
  //          break;
  //        }
  //      }
  //      if (i === -1) {
  //        i = 0;
  //      }
  //      $('.page-toc li a').removeClass('red');
  //      $('.page-toc li').eq(i).children('a').addClass('red');
  //      let height = $('.page-toc li').eq(i).position().top-$('.page-toc').height(); // 如果当前的offset出去了 回到中间可好？
  //      $('.page-toc').scrollTop(height+$('.page-toc').height()/2);
  //    },200)
  //   }

  //   $('.content').on('scroll', dark);
  // }
</script>
<style>

    /* ::-webkit-scrollbar{width:14px;}
    ::-webkit-scrollbar-track{background-color:transparent;}
    ::-webkit-scrollbar-thumb{background-color:transparent;}
    ::-webkit-scrollbar-thumb:hover {background-color:transparent}
    ::-webkit-scrollbar-thumb:active {background-color:transparent} */

    .page-toc > ul .red {
        background: #f3f3f3;
        z-index: 1;
        border-left: 3px solid #009a61;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        color: #000
    }





</style>
</body>
</html>
